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© Low power consumption microprocessor. 



© This invention relates to a microprocessor which 
reduces power consumption. Processor power con- 
sumption is reduced by monitoring the operating 
status of a plurality of operating units in the micro- 



processor to extract the unit which is recently most 
infrequently used to change the frequency of the 
operating clock supplied thereto in steps. 
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BACKGROUNDS THE INVENTION 

1. Field of the Invention 

The present invention relates to a low power 
consumption microprocessor comprising a plurality 
of operating units. 

2. Description of the Prior Art 

The general trend towards smaller sizes in 
products using large scale integration (LSI) circuit 
devices has increased the need to reduce the 
power consumption of component LSI devices. 
Various measures have been taken to reduce LSI 
device power consumption, including both device 
structure and circuit design innovations, and other 
innovations have also been applied to microproces- 
sors and microcomputers. For example, in the 
NS32CG16 microcomputer manufactured by Na- 
tional Semiconductor Corp. of the United States, 
power consumption is reduced by applying a com- 
mand to set a suitable value in the internal control 
register which changes the operating frequency of 
the microcomputer, as disclosed in National Semi- 
conductor NS32CG16 Technical Design Handbook 
1988. 

CMOS devices are used for many micropro- 
cessors as a means of achieving high integration. 
Because the power consumption of CMOS devices 
is approximately proportional to the operating fre- 
quency of the device, reducing the clock rate of the 
microcomputer within the range which will not ad- 
versely affect the processing capacity of the device 
can effectively achieve a low power consumption 
device. In addition, by using a completely static 
circuit structure in the CMOS processor, the inter- 
nal state of the processor can be maintained even 
if the operating clock is stopped. 

A method for reducing power consumption by 
controlling the operation of an oscillator or stopping 
the supply of the operating clock to the microcom- 
puter circuits by applying a command is described 
in U.S. Patents 4,748,559 and 4,758,945. However, 
because the operating frequency is changed prog- 
rammatically by these methods, it is not possible to 
continue executing a conventional program in a 
processor with a power-saving function. In addition, 
it is difficult to provide control for precision power 
reduction. 

SUMMARYOF THE INVENTION 

Therefore, an object of the present invention is 
to provide a low power consumption microproces- 
sor which can reduce the power consumed in a 
processor while retaining program compatibility. 

To achieve this object, a low power consump- 



tion microprocessor according to the present inven- 
tion comprises a clock supply means which moni- 
tors the operating status of plural operating units in 
the microprocessor to extract the unit which is 

5 recently used most infrequently and therefore re- 
duces the operating clock supplied to that unit in 
steps, a clock generating means which generates 
plural clocks, a clock selection means which se- 
lects the target clock from among plural clocks as 

70 commanded by the clock supply means, and an 
' interrupt controller which detects external interrupts 
and orders the clock supply means to raise the 
operating clock accordingly. 

A low power consumption microprocessor ac- 

;5 cording to the present invention constructed as 
thus described retains program compatibility and 
provides for reduced power consumption. 

BRIEFPESCmPTION OF THE DRAWINGS 

The present invention will become more fully 
understood from the detailed description given be- 
low and the accompanying diagrams wherein: 
Fig. 1 is a block diagram of a low power con- 
25 sumption microprocessor according to a pre- 
ferred embodiment of the present invention, 
Fig. 2 is a block diagram of the internal structure 
of the clock supply means in the first embodi- 
ment of the invention, 
30 Fig. 3 is a timing chart showing the operation of 
the preferred embodiment, 
Fig. 4 is a timing chart showing the operation of 
the clock supply means, 

Fig. 5 is a block diagram used to describe data 
35 transfer between operating units, and 

Fig. 6 is a timing chart used to describe data 
transfer between operating units. 

DESCRIPTIONOF PREFERRED EMBODIMENT 

Fig. 1 is a block diagram of a low power 
consumption microprocessor according to a pre- 
ferred embodiment of the present invention. 

As shown in Fig. 1, the microprocessor com- 

45 prises an instruction decoder 10 which controls a 
plurality of operating units 11a, 11b and 11 c by 
control signals transmitted along lines 100a, 100b 
and 100c, respectively. The operating units 11a, 
11b and 11c are each dedicated to operate particu- 

50 lar processing, for example, integer operations or 
floating point operations. Each of these operating 
units 11a, 11b and 11c produces a busy signal 
which is in a HIGH level during when the operating 
unit is in operating condition, and in a LOW level 

55 during when the operating unit is in non-operating 
condition. The busy signals from the operating 
units 11a, 11b and 11c are transmitted along lines 
101a, 101b and 101c, respectively, which are ap- 
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plied to clock selection controller 14 indicating 
whether the operating unit is operating or not 

The microprocessor further comprises: a clock 
generator 13 which generates a reference clock 
having a frequency f and transmitted along line 104 
for use internally in the microprocessor and a plu- 
rality of clocks having different frequencies, e.g., 
f/4, f/2, f, 2f, 4f and 8f and transmitted along line 
108; a clock selection controller 14 which monitors 
the operating status of each of the operating units 
11a, 11b and 11c by the busy signals transmitted 
along lines 101a, 101b and 101c, and produces 
clock selection signals along lines 102a, 102b and 
102c; and a plurality of clock selectors 12a, 12b 
and 12c each of which selects, according to the 
clock selection signal on lines 102a, 102b and 102c 
from the clock selection controller 14, one clock 
signal for use in the corresponding operating unit. 
Thus, the operating unit which is operating inten- 
sively is supplied with a relatively high frequency 
clock, the operating unit which is operating mod- 
erately is supplied with an intermediate range fre- 
quency clock, and the operating unit which is op- 
erating infrequently is supplied with a relatively low 
frequency clock. The variation of the clock fre- 
quency presented by the clock generator 13 is a 
multiple of two, but any other variation can be 
selected. 

Since the power consumed in each operating 
unit is reduced relatively to the reduction of the 
clock frequency, the operating units supplied with 
relatively low frequency clocks will consume less 
power than the normal power consumption rate. 
Thus, the power saving can be achieved. The detail 
of the clock selection controller. 14 will be given 
herein below. 

Referring to Fig. 2, a block diagram of the 
clock selection controller 14 according to the pre- 
ferred embodiment of the present invention is 
shown. The clock selection controller 14 comprises 
a cycle pulse generator 20 which generates cycle 
pulses along a line 200. For example, the cycle 
pulse generator 20 produces one cycle pulse per 
128 reference clocks from line 104 so as to deter- 
mine the cycle period of one cycle according to a 
cycle period command 105 from the instruction 
decoder 10. 

A plurality of counters 21a, 21b and 21c are 
provided each having a clear terminal CLR, a clock 
terminal CL and an overflow terminal OVF. The 
clear terminal CLR is connected to cycle pulse 
generator 20, so that the counters 21a, 21b and 
21c are cleared at the beginning of each cycle. 
The clock terminal CL is connected to an output of 
AND gate 22 through line 201. The two inputs of 
AND gate 22 are connected respectively to the 
clock generator 13 for receiving the reference clock 
and to the corresponding operation unit 100 



through line 101 to receive the busy signal. There- 
fore, when the busy signal is in HIGH level, the 
AND gate is enabled to supply the reference clock 
to counter 21 . 

5 Each counter 21 is arraigned to count up to a 

number less than the cycle period. For example, 
according to the present embodiment, counter 21 
is arranged to count up to 64 reference clocks. 
When counter 21 has counted up to 64, one over- 

70 flow pulse is produced and, at the same time, the 
counter 21 is cleared, ready for counting up again 
from the beginning. Thus, in operation, when the 
busy signal is present, counter 21 counts up the 
reference clock (frequency f), and when the busy 

15 signal is absent, counter 21 pauses to refrain from 
counting the reference clock. Thus, the counted 
result of counter 21 indicates the working rate of 
operation unit 1 1 . According to the present embodi- 
ment, since one cycle period is set equal to 128 

20 reference clocks, one overflow pulse is produced in 
one cycle when the counter 21 has counted up to 
64, meaning that the operation unit 11 has op- 
erated at the rate greater than 50% of cycle period; 
and two overflow pulses are produced in one cycle 

25 when the counter 21 has counted up to 128, mean- 
ing that the operation unit 11 has operated full rate 
with the reference clock during the cycle period. 

A minimum value detector 23 has a plurality of 
inputs for receiving the counted results from coun- 

30 ters 21a, 21b and 21c and detects which one of the 
counters is carrying the minimum value. Thus, the 
minimum value detector 23 produces a minimum 
counter signal indicative of a counter carrying the 
minimum counted value. The minimum counter sig- 

35 nal is applied through a line 203 to a decoder 24 
which produces a plurality of signals indicating the 
counter with the minimum counted value. For ex- 
ample, when the last counter 21c is carrying the 
minimum counted value, decoder 24 produces an 

40 array of signals (00.. .1). 

A plurality of up-down counters 25a, 25b and 
25c are provided each having an up-count terminal 
U, a down-count terminal D, a clear terminal CLR 
and a clock terminal CL. The up-count terminal U 

45 is connected to the overflow terminal OVF of the 
corresponding counter 21, the down-count terminal 
D is connected to the corresponding one output of 
decoder 24, the clock terminal CL is connected to 
the cycle pulse generator 20. and the clear terminal 

so CLR is connected to an output of corresponding 
OR gate 27a, 27b or 27c. 

Each of OR gates 27a, 27b and 27c has three 
inputs which are connected respectively to line 107 
for receiving an interruption signal from an interrup- 

55 tion generator 15, line 105 for receiving a clear 
command from instruction decoder 10 and line 206 
for receiving a wait signal from a wait control circuit 
26. 
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The wait control circuit 26 receives counted 
results from up-down counters 25a. 25b and 25c. 
and also the clear command from instruction de- 
coder 10, so as to detect the need for data transfer 
between units of different operating speeds. Based 
on the detected result, the wait control circuit 26 
produces a wait signal 106 to the instruction de- 
coder 10 so as to match the operating clock of the 
units by providing a clear signal along line 206. 

Referring to Fig. 3, a timing chart of operation 
of the low power consumption microprocessor ac- 
cording to the embodiment of the present invention 
is shown, particularly illustrating the change in the 
operating clock frequency of each of three units 
11a, 11b and 11c. 

At time 0, up-down counters 25 are reset to 
initial value N. Thus, N is applied through lines 
102a, 102b and 102c to clock selectors 12a. 12b 
and 12c. Thus, a clock selectors 12a. 12b and 12c 
selects and supplies clocks at the reference fre- 
quency f to operation units 11a, 11b and 11c 
during cycle 1. 

During cycle 1. each of operation units 11 a, 
11b and 11c is operated intermittently. Thus, the 
counted results of counters 21a, 21b and 21c at the 
end of cycle 1 are, for example, 48. 30 and 50. 
respectively, as indicated at the end of cycle 1 in 
Fig. 3. In this case, since the minimum number is 
30 decoder 24 provides "1 " to terminal D of up- 
down counter 25b. Thus, up-down counter 25b 
counts down to N-1 , while other counters 25a and 
25c maintains the number N. Accordingly, at the 
end of cycle 1, N is applied through lines 102a and 
102c to clock selectors 12a and 12c. Thus, clock 
selectors 12a and 12c continues to select clocks at 
the reference frequency f, which are applied to 
units 11a and 11c. Also, at the end of cycle 1, N-1 
is applied through line 102b to clock selector 12b. 
Thus, clock selector 12b changes the selection to 
select the clock with one level reduced clock fre- 
quency, e.g., f/2. 

Thus, cycle 2 starts with clock frequency f for 
units 11a and 11c, and clock frequency f/2 for unit 
11b. In this manner, the clock frequency is reduced 
to one level lower clock frequency for the operation 
unit that has the smallest operation rate in the 
previous cycle. 

At the start of cycle 3, it is assumed that clock 
selectors 12a and 12b are selecting the clocks with 
frequency f/2, and clock selector 12c is selecting 
the clock with frequency f. When the operation unit 
11c operates at a relatively high rate to have coun- 
ter 21c to count up to 64 at the mid of cycle 3, one 
overflow pulse is produced from counter 21c to 
cause up-count of counter 25c to N + 1. Thus, from 
this moment, N + 1 is applied through line 102c to 
clock selector 12c which then changes the selec- 
tion to select the clock with one level higher clock 



frequency, e.g.. 2f. When the up-count is effected 
in up-down counter 25, the D terminal is disabled 
for the instant cycle, so that the same up-down 
counter will not be decreased at the end of the 

5 cycle even if that up-down counter receives "1" to 
its D terminal. 

In this modification, the clock frequency is in- 
creased in immediate response to the generation of 
the overflow signal, even during the mid of the 

70 operation cycle, and the same is decreased at the 
end of each cycle. 

Referring to Fig. 4, another timing chart of 
operation of the low power consumption micropro- 
cessor according to the embodiment of the present 

75 invention is shown, particularly illustrating the modi- 
fication in operation of counters 21 and 25. (Only 
the signals related to units 1 la and 11b are 
shown) 

During the generation of the busy signal from 

20 operation unit 11, counter 21 counts up the refer- 
ence clock. When a counter, for example counter 
21a, has counted up to 64, an overflow signal OVF 
is generated, and the further counting of counter 
21a is terminated. In the meantime, the decoder 24 

25 coupled with minimum detector 23 produces a 
signal indicating which one of the operation units is 
being operated at the lowest rate. At the end of 
each cycle, a up/down counter which is receiving 
an overflow signal OVF. such as up/down counter 

30 25a is incremented, and a up/down counter which 
is receiving a signal indicating the lowest operation 
rate, such as up/down counter 25b is decreased. 
Thus, in the next operation cycle, clock selector 
12a selects a clock with one level higher clock 

35 frequency, e.g., 2f, and clock selector selects a 
clock with one level lower clock frequency, e.g., f/2. 

In this modification, the clock frequency is in- 
creased or decreased only at the end of each 
cycle. 

40 Referring to Figs. 5 and 6, the description is 

now directed to the operation when data is ex- 
changed between two operation units, such as 
units 11a and 11b. 

Referring particularly to Fig. 5, the data stored 

45 in a buffer of unit 1 1 a is sent through a BUS 50 to 
a latch of the operation unit 11b, and the pro- 
cessed data by the calculation means in unit 11b. 
The calculated result is shifted to a buffer in unit 
1 1 b and sent back through a BUS 52 to a latch of 

50 the operation unit 11a. The buffer in unit 11a and 
the latch in unit 11b are operated only during the 
first half clock period SO of each clock cycle 
period, and the buffer in unit 11b and the latch in 
unit 11a are operated only during the second half 

55 clock period S1 of each clock cycle period. 

Referring to Rg. 6a, a case when both units 
11a and 11b are receiving the clocks with the same 
frequency is shown. In this case, the wait control 
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circuit 26 produces on wait signal. In the first half 
clock period SO the data stored in buffer in unit 11a 
is output to the BUS 50 and further to the latch in 
unit 11b. Then, within the same half clock period 
SO, the calculation means calculates the latched 
data. 

In the second half clock period S1 of the same 
clock period, the calculated result by the unit 11b 
is shifted to the buffer thereof and further output to 
the BUS 52. Then the data is stored in the latch of 
the unit 11a. 

Referring to Fig. 6b, a case when units 11a and 
11b are receiving the clocks with different fre- 
quencies is shown. In this case, the wait control 
circuit 26 produces a wait control signal WAIT 
along line 106b and also a matching signal along 
line 206b to up/down counter 25b. The wait control 
signal WAIT continues for one clock period of the 
clock supplied to the data receiving unit 11b. In the 
first half clock period SO, operation unit 11a outputs 
the contents of the buffer in unit 11a to BUS 50. In 
this case, since the wait control circuit 26 is pro- 
ducing a WAIT signal along line 106b, the instruc- 
tion decoder 10 holds the current state until unit 
11b enters the next half clock period SO. Thus, 
when the unit 11b enters the next half clock period 
SO, the data on the BUS 50 is taken by the latch in 
unit 11b. Then, within the same half clock period 
SO, the calculation means calculates the latched 
data. 

In the next half clock period S1, the calculated 
result by the unit 11b is shifted to the buffer thereof 
and further output to the BUS 52. Then the data is 
stored in the latch of the unit 11a. 

Since the wait control circuit 26 is also produc- 
ing a matching signal to up/down counter 25b, the 
content of up/down counter 25b is matched with 
the content of up/down counter 25a, so that in the 
next clock period, the unit 11b will operate with the 
same clock frequency as that of the unit 1 1 a. 

It is to be noted that instead of the match 
signal, the wait control circuit 26 may produce a 
reset signal to both up/down counters 25a and 25b, 
so that the two counters 25a and 25b, between 
which the data exchange is to be carried out, 
produces N to cause units 11a and 11b to operate 
with the reference clock having the frequency f. 

It is also to be noted that while three operating 
units 11a, 11b and 11c were used in the above 
description, any other number of operating units 
may actually be used. 

The invention being thus described, it will be 
obvious that the same may be varied in many 
ways. Such variations are not to be regarded as a 
departure from the spirit and scope of the inven- 
tion, and all such modifications as would be ob- 
vious to one skilled in the art are intended to be 
included within the scope of the following claims. 



Claims 

1. A low power consumption microprocessor 
comprising: 

5 a plurality of operation units (11a, 11b, 

11c) for processing operations of different 
types; 

a working rate detecting means (14) for 
detecting the working rate of each of said 
io operation units (11a, 11b, 11c) and for produc- 

ing a working rate data for each unit; 

a clock generating means (13) for generat- 
ing a plurality of operation clocks of different 
frequencies relatively to various working rate 
75 data; 

a plurality of clock selecting means (12a, 
12b, 12c) coupled to said operation units, re- 
spectively, for selecting, in response to the 
receipt of said working rate data, a clock with a 
20 frequency determined by said working rate 

data. 

2. A low power consumption microprocessor as 
claimed in Claim 1, wherein each of said op- 

25 eration units (11a, 11b, 11c) produces a busy 

signal when the unit is being operated. 

3. A low power consumption microprocessor as 
claimed in Claim 2, wherein said working rate 

30 detecting means (14) comprises: 

first counter means (21, 22) provided in 
association with each unit for counting a clock 
with a predetermined frequency during the 
presence of said busy signal, and for produc- 

35 ing an overflow signal when a predetermined 

number of clocks is counted; and 

second counter means (25) provided in 
association with said first counter means for 
counting said overflow signal and for producing 

40 said working rate data relatively to the counted 

overflow signal. 

4. A low power consumption microprocessor as 
claimed in Claim 3, wherein said working rate 

45 detecting means (14) further comprises: 

minimum detector means (23, 24) for de- 
tecting a first counter means with the minimum 
counted result and for producing a decrement 
signal to said second counter means, whereby 

so said second counter means decrements said 

working rate data. 

5. A low power consumption microprocessor as 
claimed in Claim 1, further comprising instruc- 

55 tion decoder means (10) for controlling data 

exchange between the units. 

6. A low power consumption microprocessor as 
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claimed in Claim 1, further comprising wait 
control means (26) for producing a wait signal 
when two units, operating with different clock 
frequencies, exchange data. 
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Fig. 4 
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Fig. 6 a 

UNIT 11a - 

CL - 

BUFFER — 

LATCH — 
LATCH DATA 

BUS 50 Z 
BUS 52 

WAIT — 
UNIT 11b 

CL - 

LATCH IN - 

LATCH DATA. 
BUFFER — 



SO 



SO 



SI 



v- 



X3 



X 



X 



4x 




ONE CLOCK WAIT 



11 



